草庐IT

python - 在子文件夹中使用 pytest where test

全部标签

ruby - 获取实例化类 ruby​​ 的文件目录

我有一个gem,里面有这样的代码:defread(file)@file=File.newfile,"r"end现在的问题是,假设你有一个像这样的目录结构:app/main.rbapp/templates/example.txt和main.rb有如下代码:require'mygem'example=MyGem.read('templates/example.txt')它出现了FileNotFound:templates/example.txt。如果example.txt与main.rb在同一个目录中,它会工作,但如果它在一个目录中,则不会。为了解决这个问题,我在read()中添加了一个名

ruby-on-rails - Rubyzip:将 zip 文件直接导出到 S3 而无需将 tmpfile 写入磁盘?

我有这段代码,它将一个zip文件写入磁盘,读回,上传到s3,然后删除文件:compressed_file=some_temp_pathZip::ZipOutputStream.open(compressed_file)do|zos|some_file_list.eachdo|file|zos.put_next_entry(file.some_title)zos.printIO.read(file.path)endend#Writezipfiles3=Aws::S3.new(S3_KEY,S3_SECRET)bucket=Aws::S3::Bucket.create(s3,S3_BUCK

ruby - 使用适用于 Ruby 的 AWS 开发工具包发布到 SNS 主题时指定区域

我正在使用适用于Ruby的AWS开发工具包向Rails3应用程序发布消息和AWSSNS主题,如下所示:sns=AWS::SNS.newtopic=sns.topics['arn:aws:sns:eu-west-1:55555555555:my_topic']topic.publish("MESSAGE",:subject=>"SUBJECT")当我发布到“us-east-1”中的主题时,它按预期工作,但发布到“eu-west-1”区域中的主题时不起作用:AWS::SNS::Errors::InvalidParameter-Invalidparameter:TopicArn:使用AWSS

ruby - 尝试在 OSX BUILD FAILED 上使用 rbenv 安装 ruby​​ 2.1.2

所以,正如标题所示,我正在尝试安装ruby​​2.1.2,尽管我也尝试安装其他版本,但我遇到了同样的错误。我正在运行OSX10.9.2。我试过:安装新的gcc编译器,通过brewinstallgcc47安装更新的OSX命令行工具卸载rbenv并重试重启机器这是我得到的总和:rbenvinstall2.1.2Downloadingruby-2.1.2.tar.gz...->http://dqw8nmjcqpjn7.cloudfront.net/f22a6447811a81f3c808d1c2a5ce3b5f5f0955c68c9a749182feb425589e6635Installin

ruby - Rails before_action for ActionMailer 将使用邮件程序参数

假设我有一个发送不同电子邮件的邮件程序,但预计会使用相同的参数调用。我想为所有邮件操作处理这些参数。因此,调用一个before_action来读取发送到邮件程序方法的参数/mailers/my_mailer.rbclassMyMailer然后在我的Controller/服务中我在某处做MyMailer.actionx(*mailer_params).deliver_now如何访问before_actionblock中的same_param参数列表?编辑:我想重构/mailers/my_mailer.rbclassMyMailer还有这个重构/mailers/my_mailer.rbcl

ruby - 方法调用中括号的使用规则是什么?

在调用方法时,我不能在以下情况中省略括号:t=[]t.push{}#=>[]#Iexpected[{}]t.push({})#=>[{}]我应该应用什么规则来避免这种情况? 最佳答案 当您将{}作为唯一参数传递时(因此调用中没有逗号),Ruby无法判断您的意思是空散列还是空block,因此您需要使用括号区分它:t.push(){}t.push({})在其他情况下,根据经验,如果您直接将方法调用用作参数,则需要括号,即methodarg0,arg1,other_method(arg01,arg02),arg2,arg3当您的方法调用变

ruby - 我怎样才能可靠地发现 Ruby 可执行文件的完整路径?

我想写一个脚本,打包成一个gem,它将修改它的参数,然后用修改后的参数exec一个新的ruby进程。换句话说,类似于修改其参数然后执行exec$SHELL$*的shell脚本。为此,我需要一种可靠的方法来发现正在执行当前脚本的ruby​​可执行文件的路径。我还需要获取传递给当前进程的完整参数——Ruby参数和脚本参数。 最佳答案 Rake源代码是这样的:RUBY=File.join(Config::CONFIG['bindir'],Config::CONFIG['ruby_install_name']).sub(/.*\s.*/m,

ruby - 在 Ruby 中解析二进制文件

我需要能够使用Ruby解析二进制文件。此文件包含通过header找到的数据block,header包括文件偏移量和每个block的长度。如何正确取出数据?到目前为止,我一直无法根据我读出的偏移量在文件中四处寻找,因为它们以我不知道如何转换为IO#seek理解的格式的字符串形式出现。有什么帮助吗?将偏移量和长度转换为可用值(如整数或其他值)的通用方法会有所帮助。 最佳答案 你想要String#unpack. 关于ruby-在Ruby中解析二进制文件,我们在StackOverflow上找到一

ruby - 在 Ruby 中使用 Google 搜索 REST API

我正在尝试使用Ruby进行谷歌搜索,并打印前3个结果。谁能给我指出示例代码?我找不到它。 最佳答案 gemgoogleajax是为了那个吗:require'googleajax'GoogleAjax.referer="your_domain_name_here.com"GoogleAjax::Search.web("Helloworld")[:results][0...3] 关于ruby-在Ruby中使用Google搜索RESTAPI,我们在StackOverflow上找到一个类似的问题

ruby - 使用 Nokogiri(而不是 Tidy)清理 HTML

tidygem不再维护并且存在多个内存泄漏问题。有些人建议使用Nokogiri。我目前正在使用以下方法清理HTML:Nokogiri::HTML::DocumentFragment.parse(html).to_html不过我有两个问题:Nokogiri删除了DOCTYPE有没有一种简单的方法可以强制清理后的HTML具有html和body标签? 最佳答案 如果您正在处理完整文档,您需要:Nokogiri::HTML(html).to_html这将强制html和body标签,并引入或保留DOCTYPE:putsNokogiri::HT